Computers / Programming / Language References / Assembly / Intel 8080

Overview

The 8080 is an 8 bit processor released by Intel in 1974. It has an 8-bit data bus and a 16-bit address bus allowing it to access 64 KiB of memory. Originally designed for use in calculators and other electronic devices it found widespread use in early microcomputers including the Altair 8080, IMSAI 8080 and other early computers, especially those using the S-100 bus based on the Altair 8080.

CPU Registers

15
8
7
0
PSW A Flags
B B C
D D E
H H L
SP    
PC    

The 8080 has 6 general purpose 8-bit registers (B, C, D, E, H, and L) that can be referenced as three 16-bit register pairs (B, D, and H). The Accumulator (A) is an additional 8-bit register with some special capabilities. For example condition flags are typically set based on the value in A. A and the condition flags can be treated as the Program Status Word (PSW) register pair

There are also two special 16-bit registers. The Program Counter (PC) register holds the address of the next instruction to be executed. The Stack Pointer (SP) holds the address of the last value added to the stack.

Condition Flags

The 8080 has 5 flags that are set by various instructions.

Carry/Borrow

Set if a carry out occurs from an addition instruction or a borrow occurs from a subtraction.

Sign

Set based on the most-significant bit of the value in the accumulator to indicate the sign of the result.

0 - Positive

1 - Negative.

Zero

Set if the value in the accumulator is zero.

Parity

Set based on the parity of the value in the accumulator.

0 - Odd Parity

1 - Event Parity

Auxiliary Carry

Set if a carry out occurs from bit 3 of the accumulator. Used for Binary Coded Decimal instructions which treat the accumulator as two 4 bit values.

Stack Operations

The stack location is set by loading a value into SP and it expands downwards in memory. Items are added to and removed from the stack in 16-bit chunks.

Addressing Modes

The 8080 has 5 addressing modes which determine how operands are provided to the instruction.

Implied Addressing

One or more of the operands is implied by the instruction.

Register Addressing

Operand is a specified register.

Immediate Addressing

Operand is a value encoded as part of the instruction.

Direct Addressing

Address to load the operand from is encoded as part of the instruction

Register Indirect Addressing

Address to load the operand from is specified in a register pair.

Note that the M operand indicates the value at the address specified by the H/L register pair.

Instruction Set

SSS/DDD

Indicates the source register or destination register respectively

000 – Register B

001 – Register C

010 – Register D

011 – Register E

100 – Register H

101 – Register L

110 – M

111 – Accumulator

RR

Indicates a register pair

00 – B/C Register Pair

01 – D/E Register Pair

10 – H/L Register Pair

11 – Stack Pointer or Program Status Word

P

Indicates a register pair

0 – B/C Register Pair

1 – D/E Register Pair

Data

<int8> indicates a signed 8-bit value

<uint8> indicates an unsigned 8-bit value

<int16> indicates a signed 16-bit value in little endian form

<addr6> indicates a 16-bit address in little endian form

Data Transfer Instructions

Instruction Description Binary Format Octal Hex
MVI Reg, <Data>
MVI M, <Data>
Moves the immediate value to the location specified 00DDD110 <int8> 0D6 XX
STAX RegPair Stores the value in the accumulator at the address specified by register pair B/C or D/E 000P0010 0X2 X2
LDAX RegPair Loads the accumulator with the value at the address specified by register pair B/C or D/E 000P1010 0X2 XA
STA <address> Stores the value of the accumulator at the specified address 00110010 <addr16> 062 32
LDA <address> Loads the accumulator with the value at the specified address 00111010 <addr16> 072 3A
MOV Reg1, Reg2
MOV M, Reg
MOV Reg, M
Moves the value specified by the second operand to the location specified by the first operand 01DDDSSS 1DS XX

Register Pair Data Transfer Instructions

Instruction Description Binary Format Octal Hex
LXI RegPair <data>
LXI SP <Data>
Loads the specified register pair with the immediate value 00RR0001 <int16> 0X1 X1
SHLD <Address> Stores the value of L at the specified address. Stores the value of H at the specified address plus one 00100010 <addr16> 042 22
LHLD <Address> Loads L with the value at the specified address. Loads H with the value at the specified address plus one 00101010 <addr16> 052 2A
XCHG Exchanges the value in H/L register pair with the value in D/E register pair 11101011 353 EB
SPHL Loads the contents of the H/L register pair into the SP register 11111001 371 F9

Addition Instructions

Addition instructions add values to the accumulator. The carry flag is set based on the result of the operation so it can be used for chained multi-byte addition.

Instruction Description Binary Format Octal Hex
ADD Reg
ADD M
Adds the specified value to the accumulator 10000SSS 20S 8X
ADC Reg
ADC M
Adds the specified value and the carry flag to the accumulator 10001SSS 21S 8X
ADI <data> Adds the immediate value to the accumulator 11000110 <int8> 306 C6
ACI <data> Adds the immediate value and the carry flag to the accumulator 11001110 <int8> 316 CE

Subtraction Instructions

Subtraction is performed using 2’s Complement addition. The value to be subtracted is converted to it’s opposite sign value and then added to the accumulator. For example 5 (00000101) would be converted to (11111011) –5 and then added to the accumulator. The carry flag is complemented to generate a borrow flag that can be used for chained multi-byte subtraction.

Instruction Description Binary Format Octal Hex
SUB Reg
SUB M
Subtracts the specified value from the accumulator 10010SSS 22S 9X
SBB Reg
SBB M
Subtracts the specified value and the carry (borrow) flag from the accumulator 10011SSS 23S 9X
SUI <data> Subtracts the immediate value from the accumulator 11010110 <int8> 326 D6
SBI <data> Subtracts the immediate value and the carry (borrow) flag from the accumulator 11011110 <int8> 336 DE

Increment/Decrement Instructions

Instruction Description Binary Format Octal Hex
INR Reg
INR M
Adds 1 to the specified value 00DDD100 0D4 XX
DCR Reg
DCR M
Subtracts 1 from the specified value 00DDD101 0D5 XX

Register Pair Arithmetic Instructions

Instruction Description Binary Format Octal Hex
INX RegPair
INX SP
Adds 1 to the specified register pair 00RR0011 0X3 X3
DAD RegPair
DAD SP
Adds the value in the specified register pair to H/L 00RR1001 0X1 X9
DCX RegPair
DCX SP
Subtracts 1 from the specified register pair 00RR1011 0X3 XB

BCD Instructions

Binary Coded Decimal values use 4 bits to encode the decimal values 0 to 9.

Instruction Description Binary Format Octal Hex
DAA Adjusts the value in the accumulator to ensure it contains two 4-bit BCD values 00100111 047 27

Rotate Instructions

Instruction Description Binary Format Octal Hex
RLC Sets the carry flag to the most significant bit of the accumulator. Rotates the bits of the accumulator to the left by one bit with the most significant bit becoming the least significant bit. 00000111 007 07
RRC Sets the carry flag to the least significant bit of the accumulator. Rotates the bits of the accumulator to the right by one bit with the least significant bit becoming the most significant bit. 00001111 017 0F
RAL Rotates the bits of the accumulator to the left by one bit. The most significant bit of the accumulator is moved to the carry flag and the previous value of the carry flag is moved to the least significant bit of the accumulator. 00010111 027 17
RAR Rotates the bits of the accumulator to the right by one bit. The least significant bit of the accumulator is moved to the carry flag and the previous value of the carry flag is moved to the most significant bit of the accumulator. 00011111 037 1F

Logical Instructions

Instruction Description Binary Format Octal Hex
CMA Complements (Flips all bits) the accumulator 00101111 057 2F
ANA Reg
ANA M
ANDs the specified value with the accumulator 10100SSS 24S AX
XRA Reg
XRA M
Exclusive ORs the specified value with the accumulator 10101SSS 25S AX
ORA Reg
ORA M
ORs the specified value with the accumulator 10110SSS 26S BX
ANI <Data> ANDs the immediate value with the accumulator 11100110 <int8> 346 E6
XRI <Data> Exclusive ORs the immediate value with the accumulator 11101110 <int8> 356 EE
ORI <Data> ORs the immediate value with the accumulator 11110110 <int8> 366 F6

Carry Instructions

Instruction Description Binary Format Octal Hex
STC Sets the carry flag 00110111 067 37
CMC Complements the carry flag 00111111 077 3F

Compare Instructions

Compare instructions subtract the specified value from the accumulator and use the result to set the condition flags. Neither the source or the accumulator is modified.

If the zero flag is set then the values are equal.

If the two values have the same sign then the carry flag being set indicates that the value being compared is greater than the value in the accumulator otherwise the value in the accumulator is greater.

If the two values have different signs then the carry flag being indicates that the value in the accumulator is greater otherwise the value being compared is greater.

Instruction Description Binary Format Octal Hex
CMP Reg
CMP M
Compares the specified value against the accumulator 10111SSS 27S BX
CPI <Data> Compares the immediate value
against the accumulator
11111110 376 FE

Jump Instructions

Jump instructions set the PC to the address specified. Conditional jump instructions only jump if the specified condition is met.

Instruction Description Binary Format Octal Hex
JNZ <address> Jump if zero flag is clear 11000010 <addr16> 302 C2
JMP <address> Unconditional Jump 11000011 <addr16> 303 C3
JZ <address> Jump if zero flag is set 11001010 <addr16> 312 CA
JNC <address> Jump if carry flag is clear 11010010 <addr16> 322 D2
JC <address> Jump if carry flag is set 11011010 <addr16> 332 DA
JPO <address> Jump if parity flag is clear (Odd) 11100010 <addr16> 342 E2
JPE <address> Jump if parity flag is set (Even) 11101010 <addr16> 352 EA
JP <address> Jump if sign flag is clear (Positive) 11110010 <addr16> 362 F2
JM <address> Jump if sign flag is set (Minus) 11111010 <addr16> 372 FA

Call Instructions

Call instructions push the PC onto the stack and then set the PC to the address specified. Conditional Call instructions only Call if the specified condition is met.

Instruction Description Binary Format Octal Hex
CNZ <address> Call if zero flag is clear 11000100 <addr16> 304 C4
CZ <address> Call if zero flag is set 11001100 <addr16> 314 CC
CALL <address> Unconditional Call 11001101 <addr16> 315 CD
CNC <address> Call if carry flag is clear 11010100 <addr16> 324 D4
CC <address> Call if carry flag is set 11011100 <addr16> 334 DC
CPO <address> Call if parity flag is clear (Odd) 11100100 <addr16> 344 E4
CPE <address> Call if parity flag is set (Even) 11101100 <addr16> 354 EC
CP <address> Call if sign flag is clear (Positive) 11110100 <addr16> 364 F4
CM <address> Call if sign flag is set (Minus) 11111100 <addr16> 376 FC

Return Instructions

Return instructions pop the PC off of the stack and start executing at that address. Conditional return instructions only Return if the specified condition is met.

Instruction Description Binary Format Octal Hex
RNZ Return if zero flag is clear 11000000 300 C0
RZ Return if zero flag is set 11001000 310 C8
RET Unconditional Return 11001001 311 C9
RNC Return if carry flag is clear 11010000 320 D0
RC Return if carry flag is set 11011000 330 D8
RPO Return if parity flag is clear (Odd) 11100000 340 E0
PRE Return if parity flag is set (Even) 11101000 350 E8
RP Return if sign flag is clear (Positive) 11110000 360 F0
RM Return if sign flag is set (Minus) 11111000 370 F8

Program Counter Instructions

Setting the program counter to a specific value effectively results in a jump to that address

Instruction Description Binary Format Octal Hex
PCHL Sets the PC to the value in the H/L Register Pair 11101001 351 E9
RST Code Executes a Call to the address specified by the provided code multiplied by 8. 11CCC111 3C7 XX

Stack Instructions

Instruction Description Binary Format Octal Hex
POP RegPair
POP PSW
Reads the value at the address specified by SP and stores it in the low register of the register pair then increments SP and reads the next value into the high register of the register pair and then Increments SP again so it points to the next value. 11RR0001 3X1 X1
PUSH RegPair
PUSH PSW
Decrements SP and writes the value in the high register of the register pair to the address specified by SP then Decrements SP again and writes the value in the low register to the next address. 11RR0101 3X5 X5
XTHL Reads the value at the address specified by SP and exchanges it with the value in L and then reads the value at the address specified by SP plus one and exchanges it with the value in H. The value in SP is unchanged 11100011 343 E3

I/O Instructions

I/O instructions are used to communicate with other devices. The processor puts a copy of the I/O port number on the high and low parts of the address bus which is used to signal to the device that it should read or write data.

Instruction Description Binary Format Octal Hex
OUT <Port> Writes the value in the accumulator out to the specified I/O port 11010011 <uint8> 323 D3
IN <Port> Reads a value from the specified I/O port in to the accumulator 11011011 <uint8> 333 DB

Interrupt Instructions

Interrupts allow the processor to pause execution to handle a single byte instruction that is put on the bus by other devices. Typically this is a RST instruction which results in the CPU calling to a specific instruction specified by the code in the RST instruction. These can be used when a device wants to signal to the CPU that something happened.

Instruction Description Binary Format Octal Hex
DI Disables interrupts 11110011 363 F3
EI Enables Interrupts 11111011 373 FB

Machine Control Instructions

Instruction Description Binary Format Octal Hex
NOP No operation 00000000 000 00
HLT Halts the processor 01110110 166 76